import './index.styl';
import { contains } from '../../utils/index';

export default {
	data() {
		return {
			visible: false,
			index: null,
			style: {
				left: 0,
				top: 0
			},
			list: []
		};
	},

	methods: {
		open(e, options) {
			let { pageX, pageY } = e || {};
			let { list } = options || {};

			let position = {
				left: pageX,
				top: pageY
			};

			if (list) {
				this.list = list;
			}

			this.visible = true;
			this.index = null;

			this.$nextTick(() => {
				const { clientHeight: h1, clientWidth: w1 } = document.body;
				const { clientHeight: h2, clientWidth: w2 } = this.$el.querySelector(
					'.cl-context-menu-box'
				);

				if (pageY + h2 > h1) {
					position.top = h1 - h2 - 5;
				}

				if (pageX + w2 > w1) {
					position.left = w1 - w2 - 5;
				}

				this.style = position;
			});
		},

		close() {
			this.visible = false;
			this.index = null;
		},

		clickRow(e, i) {
			this.index = i;

			if (e.disabled) {
				return false;
			}

			if (e.callback) {
				return e.callback(e, () => {
					this.close();
				});
			}

			if (e.children) {
				this.$set(e, 'showChildren', !e.showChildren);
			} else {
				this.close();
			}
		}
	},

	mounted() {
		document.body.addEventListener('mousedown', e => {
			if (!contains(this.$el, e.target) && this.$el != e.target) {
				this.close();
			}
		});

		// window.onresize = () => {
		// 	this.close();
		// };
	},

	render() {
		const { left, top } = this.style;
		const slot = this.$scopedSlots.default;

		const deep = (list, level) => {
			return (
				<div class={['cl-context-menu-box', level > 1 && '_append']}>
					{list.map((e, i) => {
						let ind = `${level}-${i}`;

						return (
							<div
								class={{
									_ellipsis: e.ellipsis,
									_active: ind === this.index,
									_disabled: e.disabled
								}}>
								{e['prefix-icon'] && <i class={e['prefix-icon']}></i>}
								<span
									on-click={() => {
										this.clickRow(e, ind);
									}}>
									{e.label}
								</span>
								{e['suffix-icon'] && <i class={e['suffix-icon']}></i>}

								{e.children && e.showChildren && deep(e.children, level + 1)}
							</div>
						);
					})}
				</div>
			);
		};

		return (
			this.visible && (
				<div class="cl-context-menu" style={{ left: left + 'px', top: top + 'px' }}>
					{slot ? slot() : deep(this.list, 1)}
				</div>
			)
		);
	}
};
